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Method for optimization of temporal performances with rapid convergence 



The present invention relates to a method for optimization of temporal 
performances of a network of electronic cells, comprising a plurality of cells which are taken 
from a library, comprising several categories of cells, the cells of a same category all having 
the same functionality. 



Methods of this type are commonly used in the microelectronics industry, in 
order to improve integrated circuits. In order to make an integrated circuit capable of 
processing quickly large volumes of data, it is in fact necessary to minimize as far as possible 

1 0 the propagation times of signals which pass through said circuit. 

Most known methods for optimization require identification of at least one 
critical path, which conventionally consists of the longest passage which exists between two 
memory cells. The time which is necessary for a signal to travel along this passage 
determines a maximum frequency for the clock signals which are designed to pace the 

1 5 memory cells which delimit the critical path, and thus defines the frequency of functioning of 
the integrated circuit, and consequently a throughput of data which said circuit is capable of 
processing. A reduction in the passage time corresponding to the critical path thus permits an 
increase in the maximum value of this throughput. A method of this type for optimization, 
which identifies critical paths, is described in particular in US patent no. 5,872,717. The 

20 implementation of a method for optimization of this type has a certain number of 
disadvantages. 

Firstly, a critical path can be identified only at the expense of temporal 
analysis of all of the interconnections between the cells which constitute the network, which 
requires a considerable calculation time, owing to the volume of information to be taken into 
25 account. In addition, for a constant number of cells included in the network, the value of this 
calculation time will be greater as the complexity of the interconnections is greater. It is thus 
difficult to predict the duration necessary for identification of the critical paths, required by 
the known methods for optimization. 
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The known method additionally comprises alteration of the size of certain cells 
which intervene along the critical path identified, in order to reduce the corresponding 
passage time. However, the said cells can intervene in other data paths which will not have 
been taken into consideration, and the fact of modifying these cells can increase the duration 
5 of these other passages, and give rise to new critical paths. After each alteration of the size, it 
is therefore necessary to carry out a new identification of critical paths of the modified 
network of cells, and if necessary to replace other cells which intervene in the new critical 
paths thus identified. 

y It will be appreciated that a large number of iterations may be necessary before 

j~f 1 0 converging towards a network which will contain only critical paths with passage times 

fy which are acceptable in the light of a specification which governs the temporal performances 

fin 

S of the integrated circuit. It is also possible that a convergence of this type may never be 

MS achieved. 

3 It is apparent from the foregoing information that the known methods for 



1 5 optimization, which are based on identification of critical paths, have a significant and non- 
predictable cost of implementation, and may prove to be inefficient. 



The object of the invention is to eliminate these disadvantages, by proposing a 
20 method for optimization of temporal performances, which does not require specific 
identification or modification of critical paths of the network of cells. 

In fact, according to the invention, a method for optimization according to the 
introductory paragraph comprises the following steps: 

• accurate computation of the propagation time of signals which pass through each cell of 
25 the network; and 

• identification of cells which have a value of the propagation time computed greater than a 
predetermined reference value. 

The method according to the invention analyses in one process the behavior of 
each cell included in the network, independent of its connections with the other cells in the 
30 network. The duration of this analysis is thus independent of the complexity of the 

interconnections between the cells of the network, and depends only on the total number of 
cells. 

In addition, all the cells in the network which have an excessively long 
propagation time can simultaneously be replaced by cells which are more powerful, and 
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therefore more rapid. This eliminates the risks associated with local modifications, which 
tend to disrupt other portions of the network, and limits considerably the iterations necessary 
in order to obtain critical paths with an acceptable duration. In practice, if the reference value 
is well selected, a single iteration will be necessary, and immediate convergence can then be 
5 obtained. 

According to an embodiment of the invention, a predetermined threshold value 
valj is allocated to each cell of rank j of a same category, and when a cell of rank i identified 
must be replaced by a cell of a higher rank k, the value of k is at least equal to i+j, if the value 
of the propagation time computed for the said cell of rank i is greater than the predetermined 
'Z 1 0 threshold value valj of the cell of rank j . 

3 This embodiment of the invention makes it possible to assure that a 

0 replacement cell, which is designed to replace a cell identified as being insufficiently 

% powerful, since the value of its computed propagation time is greater than the reference 

3 value, will have sufficient power for the propagation time of the said replacement cell to be 

± 1 5 lower than the reference value, which contributes towards increasing the above-described 

* speed of convergence . 

* According to a particular embodiment of the invention, when a cell of rank i 

1 identified must be replaced by a cell of a higher rank k, the value of k is equal to i+j, if the 
value of the propagation time computed for the said cell of rank i is within the predetermined 

20 threshold values valj and valj+i of the cells of consecutive ranks j and j+1 . 

This embodiment makes it possible to assure that the power of the replacement 
cell is just great enough for its computed propagation time to be lower than the reference 
value. 

In practice, replacement of a cell which is too slow, by a more rapid cell, 
25 mostly leads to an increase in the size of the said cell, which is inherently a detrimental 

consequence, since it gives rise to an increase in the dimension of the network of cells, and 
thus of the manufacturing cost of the latter. The particular embodiment previously described 
makes it possible to reduce the extent of the detrimental effects which arise from the 
replacement operation, by limiting the increase in the size of the cell to an increase that is 
30 strictly necessary to enable the cell to have an acceptable propagation time. 

According to a variant of the invention, the execution of the replacement step 
is subject to validation by the user of the method for optimization. 
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This variant allows the user to select the cells he wishes to replace, and thus to 
control the increase in the dimension of the network, resulting from implementation of the 
method for optimization. 

In its most direct application, the invention also relates to an integrated circuit, 
5 which comprises a network of cells, the temporal performances of which have been 
optimized by means of a method such as that previously described. 

Finally, in one of its applications, the invention also relates to a receiver 
device for radio signals, which comprises an integrated circuit of this type. 

These and other aspects of the invention are apparent from and will be 
E 1 0 elucidated, by way of non-limiting example, with reference to the embodiment(s) described 
jr; hereinafter. 

; ,n 

m3 In the drawings: 

L 1 5 Fig. 1 shows a flow chart which describes a method for optimization according 

IS to an embodiment of the invention; 

U- Fig. 2 shows a diagram which makes it possible to visualize the effects of a 

u method of this type on the structure of a network of cells; 

Fig. 3 shows a diagram which illustrates a possible application of an integrated 
20 circuit which includes a network of cells of this type; and 

Fig. 4 shows an example of replacement of cells according to the method of 
optimization of figure 1 . 



25 Figure 1 shows schematically a methodological chain, which makes it possible 

to generate masks which are representative of the topography of an integrated circuit, in 
which chain a method according to the invention is implemented. 

In a first step, a user of the chain, who will usually be an integrated circuit 
designer, produces a list of interconnections NETLIST, which includes definitions of each of 

30 the cells which constitute the network, as well as a description of the input and output 
connections specific to each cell. In most applications, the cells will be logic gates, the 
models of which are listed in a library of cells LIB. This library contains several categories of 
cells, the cells of a same category all having the same functionality, and being preferentially 
arranged in increasing order of power. 



PHFR000157 



5 12.12.2001 
During a synthesis step S YNTH, the user executes a synthesis program, 
which, on the basis of the list of interconnections, generates a drawing, Layout, of the 
topography of the network of cells. 

During a temporal analysis step TAS, a computation program computes 
5 accurately propagation times dt of signals, which pass through each cell of the network. To 
this end, said program is based on source file currently called SPEF "Standard Parasitic 
Extraction Format" comprising physical parameters such as capacitances or resistances. Said 
physical parameters come from a mask representing physically the circuit, said mask being 
conceived during a known step of place and route called "Back-End". The computation 
n 1 0 program extracts a final file at the standard format SDF "Standard Delay Format", said file 
m comprising the propagation times computed. It can be noted that by computing accurately the 

00 propagation time dt for each cell, we avoid having an important margin of error on said time 

% at the end of the cells treatment and in particular during the replacement of some cells. Thus, 

fi it avoids to make a big number of iterations and consequently, it avoids to diverge from the 

u 1 5 network we want to obtain. 

JJf Programs of this type, for synthesis and computation, are common logic tools, which are 

M= available on the market for software to assist the design of integrated circuits. 

rT During a detection step DET, each computed propagation time value dt is 

compared with a reference value Ref, which is predetermined by the user. If no computed 
20 propagation time value dt is greater than the reference value Ref, this means that the temporal 
performances of the network of cells defined by the list of interconnections NETLIST are 
acceptable for the user, according to a specification with which the integrated circuit which 
he is designing must comply. The list of interconnections NETLIST is then validated, 
without needing to be modified. If, on the other hand, certain computed propagation time 
25 values dt are greater than the reference value Ref, this means that, in principle, the 

corresponding cells must be replaced by more powerful cells with the same functionality, 
which have shorter propagation times. 

These cells are identified during an identification step ID, and, in the particular 
embodiment of the invention now described, a display step STAT/DISP informs the user of 
30 the existence of these cells, which are liable to be replaced. In practice, the display itself can 
take various forms, such as a list of the cells which are liable to be replaced, their physical 
location in the topography Layout, and/or statistical data, such as the ratio between the 
number of cells which are liable to be replaced, and the total number of cells included in the 
network, or a ratio of the corresponding surface areas. 
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In this embodiment of the invention, a validation step EN subjects the 
execution of replacements to validation by the user, who, by means of a message Rep Y/N, 
determines whether a cell which is liable to be replaced must be replaced or not. This 
validation can be carried out case by case, but the user can also be left the possibility of 
5 determining simply a percentage of the number of cells effectively liable to be replaced, for 
example a percentage of 5%, and the cells to be replaced can then be selected randomly by 
the method for optimization. Thus, the choice of the percentage of the cells to be modified, 
and in particular if a small percentage is taken compared to the number of existing cells, 
enables to modify said cells very fast without error during the place and route step, such a 
P 1 0 modification of cells being called ECO "Engineering Change Order". 

In the example now described, the actual replacement of each cell which is 
^ liable to be replaced, the identity Ci of which has been stored during the identification step 

y3 ID, requires validation by the user. If the user chooses not to modify any cell, or not to 

modify the final cell which is liable to be replaced, known as Lei, the list of interconnections 
H 1 5 NETLIST is validated in its fast state. The replacement of a cell which is liable to be replaced 
ry Ci is carried out as follows: 

% During a comparison step CMP, the computed propagation time dti of the cell 

M which is liable to be replaced Ci is compared with predetermined threshold values valj 

allocated to various cells Cj, which belong to the same category as the cell which is liable to 
20 be replaced Ci, and are present in the library LIB. Preferentially, there are four threshold 
values valj. 

These values valj are temporal values, and increase according to the rank of 
the cells Cj. They are issued by the library LIB, which is then configurable, in the form of a 
word Val (1 :P) in this example, which means that each category comprises P cells with the 

25 same functionality, arranged in increasing order of power, from 1 to P. 

On completion of the comparison step CMP, the rank k of a cell Ck which is 
designed to replace the cell which is liable to be replaced Ci, with a rank i, is identified and 
defined as being equal to i+j, if the value of the computed propagation time dti for the cell 
which is liable to be replaced Ci is within the predetermined threshold values valj and valj+i 

30 of the cells of consecutive ranks j and j+1 , which can be written in the form k=i+j, if 
valj<dti<valj+i. 

Figure 4 shows an example of possible replacement according to a category of 
cells. Thus, in this example, 4 threshold values valjl, valj2, valj 3 and valj4, and two 
categories of cells are illustrated. There is a cell of category CO, which can be replaced by 
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one of the four possible replacement cells CI, C2, C3 and C4 of the same category according 
to their corresponding threshold values. Likewise, there is a cell of category CI, which can be 
replaced by one of the four possible replacement cells C3, C5, C6 and C7 of the same 
category. For example, if a cell of category CI which is liable to be replaced has a 
5 propagation time dtl which is greater than valj2 and smaller than valj3, the cell of rank k=3 is 
C6. 

During a replacement step REP, the parameters which define the model of the 
replacement cell Ck are taken from the library LIB, and replace those of the cell which is 
liable to be replaced Ci within the list of interconnections NETLIST. 
1 0 If this is the final cell which is liable to be replaced LCi, the list of 

interconnections NETLIST is validated in this state. Otherwise, the replacement of a new cell 
which is liable to be replaced Ci, identified during the identification step ID, is submitted for 
validation to the user, during a new validation step EN. 

For a cell which is liable to be replaced Ci to which no replacement cell Ck 
1 5 defined in the library LIB corresponds, no replacement is done. These cells, which are liable 
to be replaced are memorized in a file. This file can be used later on in order to find another 
solution to solve the problem of the cells, which are not replaced. 

When the list of interconnections NETLIST has been validated, it will be 
sufficient to execute the synthesis step SYNTH, in order to obtain a drawing, Layout, of the 
20 topography of the optimized network of cells, in its definitive state. 

It can be seen that the method for optimization according to the invention is 
simple to implement, and is easy for the user to control. 

On completion of a single temporal analysis step TAS, all the cells which have 
an excessively lengthy propagation time can be replaced, which assists convergence towards 
25 a network with temporal performances which are acceptable to the user. 

Moreover, thanks to the possible parameterization of the reference value Ref 
and of the threshold values valj by the user, a great flexibility is acquired at the level of the 
treatment of the cells. According to the technology of the circuit that is used, the values Ref 
and valj are parameterized differently. For example, for a technology of 0.2 microns, the 
30 reference value Ref is 0.4ns, whereas for example, four threshold values valj are 0.4ns, 0.6ns, 
0.85ns and Ins. In an empiric manner, a good reference value Ref can be equal to the 
technology used for an average propagation time. However, in order to take into account the 
propagation times which are greater, the reference value can be preferentially taken equal to 
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two times the technology used, which is the case in the example taken of the technology of 
0.2 microns, as the value is 0.4ns. 

Figure 2 makes it possible to visualize the physical consequences of 
implementation of the method for optimization according to the invention. This figure shows 
5 schematically the drawing, Layout, of the topography of the network of cells obtained on 
completion of the synthesis step. This network contains three cells which are liable to be 
replaced, shown in bold in this example, and are identified as such on completion of the steps 
of temporal analysis, detection and identification. Subject to validation by the user, these 
j s cells will be replaced respectively by cells Clk, C2k and C3k which are in the same category 

O 10 but are more powerful, the mask design of which will be taken from the library LIB. 
m Although, in order to facilitate identification of each cell which is liable to be 

replaced, and of its replacement Clk (for 1=1 to 3), the said cells have identical dimensions in 

SjSC? 

£l the Figure, it will be appreciated that in practice, the surface area of the replacement cell Clk 

will be larger than that of the cell which is liable to be replaced. 
^ 15 It is understood that it is possible that the replacement of a cell, which is liable 

ffy to be replaced by another cell, influences the neighbored cells, which lead to the modification 

L of the propagation time of the cell computed previously. However, said modification is very 

H slight and has no consequence on the circuit. There is no divergence observed and it is not 

necessary to apply a big number of iterations in the temporal analysis. 
20 Figure 3 illustrates one of the many possible applications of the invention. 

This figure shows highly schematically a radio signal receiver device, in this case a mobile 
telephone TEL, which comprises an integrated circuit IC, comprising a network of cables, the 
topography, Layout, of which, has been optimized by means of a method for optimization 
according to the invention. 



